草庐IT

iOS 多线程1 --任务与队列

全部标签

ruby-on-rails - Rails 中的多线程 : Circular dependency detected while autoloading constant

我有一个Rails应用程序,其中有一个Rake任务,该任务使用并发rubygem提供的多线程函数。有时我会遇到Circulardependencydetectedwhileautoloadingconstant错误。在谷歌搜索了一下后,我发现这与结合使用线程和加载Rails常量有关。我偶然发现了以下GitHub问题:https://github.com/ruby-concurrency/concurrent-ruby/issues/585和https://github.com/rails/rails/issues/26847如此处所述,您需要将从新线程调用的所有代码包装在Rails.a

ruby-on-rails - rails 周期性任务

我有一个ruby​​onrails应用程序,我试图在其中找到每隔几秒运行一些代码的方法。我发现了很多使用cron或类似cron的实现的信息和想法,但这些只是准确到分钟,并且/或需要外部工具。我想每15秒左右启动一次任务,并且我希望它完全独立于应用程序中(如果应用程序停止,任务也停止,并且没有外部设置)。这用于缓存数据的后台生成。每隔几秒,任务就会收集一些数据,然后将其存储在缓存中,供所有客户端请求使用。该任务非常慢,因此需要在后台运行并且不阻塞客户端请求。我是ruby​​的新手,但有很强的perl背景,我解决这个问题的方法是创建一个间隔计时器和处理程序,它fork、运行代码,然后在完成

ruby - 如何以编程方式一次运行多个 Rake 任务?

在命令行我可以像这样运行多个任务rakeenvironmenttask1task2task3我如何以编程方式执行此操作?我知道我可以像这样运行一项任务Rake::Task['task1'].invoke 最佳答案 你可以调用两个任务:require'rake'task:task1do|t|ptendtask:task2do|t|ptendRake::Task["task1"].invokeRake::Task["task2"].invoke我更喜欢有先决条件的新口味:require'rake'task:task1do|t|ptend

ruby - 线程池中的死锁

我找不到适合Ruby的ThreadPool实现,所以我写了我的(部分基于这里的代码:http://web.archive.org/web/20081204101031/http://snippets.dzone.com:80/posts/show/3276,但更改为等待/信号和ThreadPool关闭的其他实现。但是在运行一段时间后(有100个线程并处理大约1300个任务),它在第25行死锁-它在那里等待新工作。任何想法,为什么会发生?require'thread'beginrequire'fastthread'rescueLoadError$stderr.puts"Usingther

ruby - 如何将参数从父任务传递到 Rake 中的子任务?

我正在编写一个Rake脚本,其中包含带参数的任务。我弄清楚了如何传递参数以及如何使任务依赖于其他任务。task:parent,[:parent_argument1,:parent_argument2,:parent_argument3]=>[:child1,:child2]do#PerformParentTaskFunctionalitiesendtask:child1,[:child1_argument1,:child1_argument2]do|t,args|#PerformChild1TaskFunctionalitiesendtask:child2,[:child2_argum

ruby - 如何在 rake 任务的字符串参数中使用逗号?

我有以下Rakefile:task:test_commas,:arg1do|t,args|putsargs[:arg1]end并希望使用包含逗号的单个字符串参数来调用它。这是我得到的:%rake'test_commas[foo,bar]'foo%rake'test_commas["foo,bar"]'"foo%rake"test_commas['foo,bar']"'foo%rake"test_commas['foo,bar']"'foo%rake"test_commas[foo\,bar]"foo\我目前正在使用此pullrequesttorake中提出的解决方法,但有没有办法在不修

ruby-on-rails - 如何运行使用我的 Rails 模型的 Ruby 任务?

我有一个带有一些基本模型的Rails应用程序。该网站显示从其他来源检索的数据。所以我需要编写一个Ruby脚本来在我的数据库中创建新实例。我知道我可以使用测试Hook来做到这一点,但我不确定这在这里是否有意义。我不确定这个任务应该是什么样子,我如何调用它,或者它应该在我的源代码树中的什么位置(lib\tasks?)。例如,这是我的第一次尝试:require'active_record'require'../app/models/mymodel.rb'test=MyModel.newtest.name='test'test.save这失败了,因为它无法连接到数据库。这对我的新手来说意义不大

ruby - 是否有一种简单的方法来检查 Ruby IO 实例是否会阻塞 read()?

我正在寻找一种Ruby中的方法,基本上是这样的:io.ready_for_read?我只想检查给定的IO对象(在我的例子中是popen调用的结果)是否有可用的输出,即后续调用io.read(1)不会阻塞。这是我看到的两个选项,我都不喜欢:io.read_nonblock-Unixread()的抽象太薄了-我不想处理errno错误处理。io.selectwithtimeout0--混淆了这个简单操作的目的。有没有我忽略的更好的选择? 最佳答案 有点晚了,但是如果您需要'io/wait',您可以使用ready?来验证IO是否可以无阻塞地

ruby-on-rails - 如何在 rails 中通过命令行运行 rake 任务

我在名为file_locker_task.rake的文件中定义了一个rake任务,如下所示namespace:myspacedotask:process=>:environmentdoFileLocker.lock_filesendend如何从命令行执行此rake任务?我试过:rakemyspace:process和rakeprocess但两者都抛出如下错误:rakeaborted!Don'tknowhowtobuildtask'process' 最佳答案 从您的Rails主目录运行rake-T-A以查看rake知道的所有任务。你的

ruby - 你如何在 Rake 任务之间进行通信?

假设我有一个需要编译一些文件的目标。该目标有另一个目标作为先决条件,即获取文件的目标。让我们这样说:task:obtaindo#obtainfilesfromsomewhereendtask:compile=>:obtaindo#docompilationend假设:obtain目标并不总是将文件放在同一个文件夹中。我如何将:compile传递给:obtain找到的路径?环境变量? 最佳答案 在我看来,使用ENV['something']更可取,因为如果你这样做(而不是$global或@instance变量),你可以将它们视为任务参